package com.bascker.algorithm.practice.sliding_window.easy.contains_near_by_duplicate;

import java.util.HashMap;
import java.util.Map;

public class Solution2 {

    public boolean containsNearbyDuplicate(int[] nums, int k) {
        int n = nums.length;

        // key - nums[i], value: index
        final Map<Integer, Integer> dict = new HashMap<>();
        for (int i = 0; i < n; i ++) {
            // 若存在相同数据，且满足索引的要求
            if (dict.containsKey(nums[i]) && i - dict.get(nums[i]) <= k) {
                return true;
            }

            // 滚动相同数据到最近的一个索引位置
            dict.put(nums[i], i);
        }


        return false;
    }

}
